<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>

</head>

<body>
    <div id="root">
        <h1>学生信息</h1> <br>

        <button @click="student.age++">年龄+1</button><br>
        <button @click="addSex">添加性别属性, 默认值:男</button><br>
        <button @click="student.sex = '未知'">修改性别</button><br>
        <button @click="addFriend">在列表首位添加一个朋友</button><br>
        <button @click="updateFirstFriendName">修改第一个朋友的名字为:张三</button><br>
        <button @click="addHobby">添加一个爱好</button><br>
        <button @click="updateHobby">修改第一个爱好为:开车</button><br>
        <button @click="removeSmoke">过滤掉爱好中的抽烟</button>


        <h3>姓名: {{student.name}}</h3>
        <h3>年龄: {{student.age}}</h3>
        <h3 v-show="student.sex">性别: {{student.sex}}</h3>
        <h3>爱好: </h3>
        <ul>
            <li v-for="(h,index) in student.hobby" ::key="index">
                {{h}}
            </li>
        </ul>
        <h3>朋友们: </h3>
        <ul>
            <li v-for="(f,index) in student.friends" ::key="index">
                {{f.name}} -- {{f.age}}
            </li>
        </ul>
    </div>

</body>


</html>
<script>

    const vm = new Vue({
        el: '#root',
        data: {
            student: {
                name: 'tom',
                age: 18,
                hobby: ['抽烟', '喝酒', '烫头'],
                friends: [
                    { name: 'jerry', age: 35 },
                    { name: 'tony', age: 36 }
                ]
            }
        },
        methods: {
            addSex() {
                // Vue.set(this.student, 'sex', '男')
                this.$set(this.student, 'sex', '男')
            },
            addFriend() {
                this.student.friends.unshift({ name: 'jack', age: 70 })
            },
            updateFirstFriendName() {
                this.student.friends[0].name = '张三'
            },
            addHobby() {
                this.student.hobby.push('学习')
            },
            updateHobby() {
                // this.student.hobby.splice(0, 1, '开车')
                // Vue.set(this.student.hobby, '0', '开车')
                this.$set(this.student.hobby, '0', '开车')
            },
            removeSmoke() {
                this.student.hobby = this.student.hobby.filter((h) => {
                    return h !== '抽烟'
                })
            }
        }
    })

</script>
<!-- 
    Vue监视数据的原理
        1. vue会监视data中所有层次的数据
        2. 如果监测对象中的数据?
            通过setter实现监视, 且要在new Vue时就传入要监测的数据
                a. 对象中后追加的属性, Vue默认不做响应式处理
                b. 如需给后添加的属性响应式, 请使用以下API
                    Vue.set(target,properyName/index,value) 或
                    vm.$set(target,properyName/index,value)
        3. 如何监测数组中的数据
            通过包裹数组更新元素的方法实现, 本质就是做了两件事
                a. 调用原生对应的方法对数组进行更新
                b. 重新解析模板, 进行更新页面
        4. 在Vue修改数组中的某一个元素一定要用以下方法:
            a. 使用这些API: push(), shift(), unshift(), splice(), sort, reverset()
            b. Vue.set()或vm.$set
        特别注意: Vue.set()和vm.$set()不能给vm或vm的根数据对象添加属性!!!
 -->